## APPENDIX B

**INSTRUCTION LIST** 

ALPHABETIC BY MNEMONIC

WITH OP CODES, EXECUTION CYCLES

AND MEMORY REQUIREMENTS

The following notation applies to this summary:

| <b>A</b>        | Accumulator               |  |  |  |
|-----------------|---------------------------|--|--|--|
| Х, Ү            | Index Registers           |  |  |  |
| М               | Memory                    |  |  |  |
| P               | Processor Status Register |  |  |  |
| S               | Stack Pointer             |  |  |  |
| √               | Change                    |  |  |  |
|                 | No Change                 |  |  |  |
| +               | Add                       |  |  |  |
| Λ               | Logical AND               |  |  |  |
| -               | Subtract                  |  |  |  |
| ₩ .             | Logical Exclusive Or      |  |  |  |
| <b>†</b>        | Transfer from Stack       |  |  |  |
| <b>‡</b>        | Transfer to Stack         |  |  |  |
| <b>→</b>        | Transfer to               |  |  |  |
| <del>&lt;</del> | Transfer to               |  |  |  |
| V               | Logical OR                |  |  |  |
| PC              | Program Counter           |  |  |  |
| PCH             | Program Counter High      |  |  |  |
| PCL             | Program Counter Low       |  |  |  |
| OPER            | OPERAND                   |  |  |  |
| #               | IMMEDIATE ADDRESSING MODE |  |  |  |

Note: At the top of each table is located in parentheses a reference number (Ref: XX) which directs the user to that Section in the MCS6500 Microcomputer Family Programming Manual in which the instruction is defined and discussed.

Operation:  $A + M + C \rightarrow A$ , C

N Z C I D V

(Ref: 2.2.1)

√ √ √ -- √

| Addressing<br>Mode | Assem | bly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles |
|--------------------|-------|----------------------|------------|--------------|---------------|
| Immediate          | ADC   | # Oper               | 69         | 2            | 2             |
| Zero Page          | ADC   | Oper                 | 65         | 2            | 3             |
| Zero Page, X       | ADC   | Oper, X              | 75         | 2            | 4             |
| Absolute           | ADC   | Oper                 | 6D         | 3            | 4             |
| Absolute, X        | ADC   | Oper, X              | 7D         | 3            | 4*            |
| Absolute, Y        | ADC   | Oper, Y              | 79         | 3            | 4*            |
| (Indirect, X)      | ADC   | (Oper, X)            | 61         | 2            | 6             |
| (Indirect), Y      | ADC   | (Oper), Y            | 71         | 2            | 5*            |

<sup>\*</sup> Add 1 if page boundary is crossed.

**ASL** 

ASL Shift Left One Bit (Memory or Accumulator)

**ASL** 

Operation:  $C \leftarrow 76543210$ 

N Z C I D V

(Ref: 10.2)

| Addressing                                              | Assembly Language                            | OP                         | No.                   | No.                   |
|---------------------------------------------------------|----------------------------------------------|----------------------------|-----------------------|-----------------------|
| Mode                                                    | Form                                         | CODE                       | Bytes                 | Cycles                |
| Accumulator Zero Page Zero Page, X Absolute Absolute, X | ASL A ASL Oper ASL Oper, X ASL Oper ASL Oper | ØA<br>Ø6<br>16<br>ØE<br>1E | 1<br>2<br>2<br>3<br>3 | 2<br>5<br>6<br>6<br>7 |

**BCC** 

BCC Branch on Carry Clear

**BCC** 

Operation: Branch on C = Ø

NZCIDV

(Ref: 4.1.1.3)

| Addressing | Assembly Language | OP   | No.   | No.    |
|------------|-------------------|------|-------|--------|
| Mode       | Form              | CODE | Bytes | Cycles |
| Relative   | BCC Oper          | 9Ø   | 2     | 2*     |

<sup>\*</sup> Add 1 if branch occurs to same page.

<sup>\*</sup> Add 2 if branch occurs to different page.

**BCS** 

## BCS Branch on carry set

**BCS** 

Operation: Branch on C = 1

NZCIDV

(Ref: 4.1.1.4)

| Addressing | Assembly Language | OP   | No.   | No.    |
|------------|-------------------|------|-------|--------|
| Mode       | Form              | CODE | Bytes | Cycles |
| Relative   | BCS Oper          | вø   | 2     | 2*     |

- \* Add 1 if branch occurs to same page.
- $\star$  Add 2 if branch occurs to next page.

**BEQ** 

BEQ Branch on result zero

BEQ

Operation: Branch on Z = 1

(Ref: 4.1.1.5)

N Z C I D V

| Addressing | Assembly Language | OP   | No.   | No.    |
|------------|-------------------|------|-------|--------|
| Mode       | Form              | CODE | Bytes | Cycles |
| Relative   | BEQ Oper          | FØ   | 2     | 2*     |

- \* Add 1 if branch occurs to same page.
- \* Add 2 if branch occurs to next page.

BIT

BIT

Operation: A  $\wedge$  M, M<sub>7</sub>  $\rightarrow$  N, M<sub>6</sub>  $\rightarrow$  V

Bit 6 and 7 are transferred to the status register. N  $\pm$  C I D V If the result of A  $\wedge$  M is zero then Z = 1, otherwise  $M_7 \sqrt{---} M_6$ 

 $Z = \emptyset$ 

(Ref: 4.2.1.1)

| Addressing            | Assembly Language | OP       | No.   | No.    |
|-----------------------|-------------------|----------|-------|--------|
| Mode                  | Form              | CODE     | Bytes | Cycles |
| Zero Page<br>Absolute | BIT Oper          | 24<br>2C | 2     | 3<br>4 |

BMI

BMI Branch on result minus

BM

Operation: Branch on N = 1

N Z C I D V

(Ref: 4.1.1.1)

| Addressing | Assembly Language | OP         | No.   | No.    |
|------------|-------------------|------------|-------|--------|
| Mode       | Form              | CODE       | Bytes | Cycles |
| Relative   | BMI Oper          | 3 <b>ø</b> | 2     | 2*     |

<sup>\*</sup> Add 1 if branch occurs to same page.

<sup>\*</sup> Add 2 if branch occurs to different page.

**CMP** 

CMP Compare memory and accumulator

**CMP** 

Operation: A - M

NZCIDV VVV---

(Ref: 4.2.1)

| Addressing<br>Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles |
|--------------------|---------------------------|------------|--------------|---------------|
| Immediate          | CMP #Oper                 | C9         | 2            | 2             |
| Zero Page          | CMP Oper                  | C5         | 2            | 3             |
| Zero Page, X       | CMP Oper, X               | D5         | 2            | 4             |
| Absolute           | CMP Oper                  | CD         | 3            | 4             |
| Absolute, X        | CMP Oper, X               | DD         | 3            | 4*            |
| Absolute, Y        | CMP Oper, Y               | D9         | 3            | 4*            |
| (Indirect, X)      | CMP (Oper, X)             | C1         | 2            | 6             |
| (Indirect), Y      | CMP (Oper), Y             | Dl         | 2            | 5*            |

<sup>\*</sup> Add 1 if page boundary is crossed.

CPX

**CPX** Compare Memory and Index X

**CPX** 

Operation: X - M

N  $\Xi$  C I D V  $\checkmark$   $\checkmark$   $\checkmark$  - -

(Ref: 7.8)

| Addressing<br>Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles |
|--------------------|---------------------------|------------|--------------|---------------|
| Immediate          | CPX #Oper                 | ЕØ         | 2            | 2             |
| Zero Page          | CPX Oper                  | E4         | 2            | 3             |
| Absolute           | CPX Oper                  | EC         | 3            | 4             |

**CPY** 

CPY Compare memory and index Y

**CPY** 

Operation: Y - M

N Z C I D V

(Ref: 7.9)

| Addressing | Assembly Language | OP   | No.   | No.    |
|------------|-------------------|------|-------|--------|
| Mode       | Form              | CODE | Bytes | Cycles |
| Immediate  | CPY #Oper         | CØ   | 2     | 2      |
| Zero Page  | CPY Oper          | C4   | 3     | 3      |
| Absolute   | CPY Oper          | CC   |       | 4      |

**JMP** 

JMP Jump to new location

**JMP** 

 $N \neq C I D V$ 

Operation: (PC + 1) → PCL

 $(PC + 2) \rightarrow PCH$ 

(Ref: 4.0.2) (Ref: 9.8.1)

| Addressing | Assembly Language | CODE | No.   | No.    |
|------------|-------------------|------|-------|--------|
| Mode       | Form              |      | Bytes | Cycles |
| Absolute   | JMP Oper          | 4C   | 3     | 3      |
| Indirect   | JMP (Oper)        | 6C   |       | 5      |

**JSR** 

JSR Jump to new location saving return address

**JSR** 

| Addressing | Assembly Language | OP   | No.   | No.    |
|------------|-------------------|------|-------|--------|
| Mode       | Form              | CODE | Bytes | Cycles |
| Absolute   | JSR Oper          | 20   | 3     |        |

LSR

LSR Shift right one bit (memory or accumulator)

LSR

Operation:  $\emptyset \rightarrow \boxed{76543210} \rightarrow 0$ 

N Z C I D V

ø √ √ — — —

(Ref: 10.1)

| Addressing                                              | Assembly Language                            | OP                         | No.                   | No.                   |
|---------------------------------------------------------|----------------------------------------------|----------------------------|-----------------------|-----------------------|
| Mode                                                    | Form                                         | CODE                       | Bytes                 | Cycles                |
| Accumulator Zero Page Zero Page, X Absolute Absolute, X | LSR A LSR Oper LSR Oper, X LSR Oper LSR Oper | 4A<br>46<br>56<br>4E<br>5E | 1<br>2<br>2<br>3<br>3 | 2<br>5<br>6<br>6<br>7 |

ROL

ROL Rotate one bit left (memory or accumulator)

ROL

Operation:

N Z C I D V

(Ref: 10.3)

| Addressing<br>Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles |
|--------------------|---------------------------|------------|--------------|---------------|
| Accumulator        | ROL A                     | 2A         | 1            | 2             |
| Zero Page          | ROL Oper                  | 26         | 2            | 5             |
| Zero Page, X       | ROL Oper, X               | 36         | 2            | 6             |
| Absolute           | ROL Oper                  | 2E         | 3            | 6             |
| Absolute, X        | ROL Oper, X               | 3E         | 3            | 7             |

**ROR** 



| Addressing<br>Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles |
|--------------------|---------------------------|------------|--------------|---------------|
| Accumulator        | ROR A                     | 6A         | 1            | 2             |
| Zero Page          | ROR Oper                  | 66         | 2            | 5_            |
| Zero Page,X        | ROR Oper,X                | 76         | 2            | 6             |
| Absolute           | ROR Oper                  | 6E         | 3            | 6             |
| Absolute,X         | ROR Oper,X                | 7E         | 3            | 7             |

Note: ROR instruction will be available on MCS650X micro-processors after June, 1976.

RTI

RTI Return from interrupt

RTI

Operation: P↑ PC↑

NZCIDV

(Ref: 9.6)

From Stack

| Addressing<br>Mode | Assembly Language<br>Form | CODE | No.<br>Bytes | No.<br>Cycles |
|--------------------|---------------------------|------|--------------|---------------|
| Implied            | RTI                       | 40   | 1            | 6             |

**RTS** 

RTS Return from subroutine

**RTS** 

Operation: PC $\uparrow$ , PC + 1 $\rightarrow$  PC

NZCIDV

(Ref: 8.2)

| Addressing | Assembly Language | OP         | No.   | No.    |
|------------|-------------------|------------|-------|--------|
| Mode       | Form              |            | Bytes | Cycles |
| Implied    | RTS               | 6 <b>Ø</b> | 1     | 6      |

**SBC** 

SBC Subtract memory from accumulator with borrow

**SBC** 

Operation: A - M -  $\overline{C}$   $\rightarrow$  A

NZCIDV

Note:  $\overline{C} = Borrow$  (Ref: 2.2.2)

√ √ √ -- √

| Addressing<br>Mode | Assembly Language<br>Form | OP<br>CODE | No.<br>Bytes | No.<br>Cycles |
|--------------------|---------------------------|------------|--------------|---------------|
| Immediate          | SBC #Oper                 | E9         | 2            | 2             |
| Zero Page          | SBC Oper                  | E5         | 2            | 3             |
| Zero Page, X       | SBC Oper, X               | F5         | 2            | 4             |
| Absolute           | SBC Oper                  | ED         | 3            | 4             |
| Absolute, X        | SBC Oper, X               | FD         | 3            | 4*            |
| Absolute, Y        | SBC Oper, Y               | F9         | 3            | 4*            |
| (Indirect, X)      | SBC (Oper, X)             | E1         | 2            | 6             |
| (Indirect), Y      | SBC (Oper), Y             | F1         | 2            | 5*            |

<sup>\*</sup> Add 1 when page boundary is crossed.

# APPENDIX C

INSTRUCTION ADDRESSING

MODES AND

RELATED EXECUTION TIMES

| beilqml Aslative (X ,tseribnl) (Y,(tseribnl) tseribnl etulosdA                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Accumulator Immediate Zero Page, X Zero Page, Y Zero Page, Y Absolute X testulosdA Y Absolute, X |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Pelative (X.) (Indirect, X.) Y.(Indirect).                                                       | 6 5* LDA 2** LDA 2** LDA 2** LDA 2** LDA 2** LDA 2** LSR 2** ROP 2** ROL 2** R |
| Page One Nege X Sero Page X X Page X X Page Y X X Y Y Y Y Y Y Y Y Y Y Y Y Y Y Y Y                | 22       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2       .2 <td< td=""></td<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| rotelumusaA                                                                                      | AND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

## APPENDIX E

SUMMARY OF ADDRESSING MODES

This appendix is to serve the user in providing a reference for the MCS650X addressing modes. Each mode of address is shown with a symbolic illustration of the bus status at each cycle during the instruction fetch and execution. The example number as found in the text is provided for reference purposes.

### E.1 IMPLIED ADDRESSING

Example 5.3: Illustration of implied addressing

| Clock<br>Cycle | Address Bus | Program Counter | Data Bus       | Comments                                        |
|----------------|-------------|-----------------|----------------|-------------------------------------------------|
| 1              | PC          | PC + 1          | O. CODE        | Fetch OP CODE                                   |
| 2              | PC + 1      | PC + 1          | New<br>OP CODE | Ignore New<br>OP CODE;<br>Decode Old<br>OP CODE |
| 3              | PC + 1      | PC + 2          | New<br>OP CODE | Fetch New<br>OP CODE;<br>Execute Old<br>OP CODE |

### E.2 IMMEDIATE ADDRESSING

Example 5.4: Illustration of immediate addressing

| Clock<br>Cycle | Address Bus | Program Counter | Data Bus       | Comments                                        |
|----------------|-------------|-----------------|----------------|-------------------------------------------------|
| 1              | PC          | PC + 1          | OP CODE        | Fetch OP CODE                                   |
| 2              | PC + 1      | PC + 2          | Data           | Fetch Data,<br>Decode OP CODE                   |
| 3              | PC + 2      | PC + 3          | New<br>OP CODE | Fetch New<br>OP CODE,<br>Execute Old<br>OP CODE |

### E.3 ABSOLUTE ADDRESSING

Example 5.5: Illustration of absolute addressing

| Clock<br>Cycle | Address Bus | Program Counter | Data Bus       | Comments                                        |
|----------------|-------------|-----------------|----------------|-------------------------------------------------|
| 1              | PC          | PC + 1          | OP CODE        | Fetch OP CODE                                   |
| 2              | PC + 1      | PC + 2          | ADL            | Fetch ADL,<br>Decode OP CODE                    |
| 3              | PC + 2      | PC + 3          | ADH            | Fetch ADH,<br>Retail ADL                        |
| 4              | ADH, ADL    | PC + 3          | Data           | Fetch Data                                      |
| 5              | PC + 3      | PC + 4          | New<br>OP CODE | Fetch New<br>OP CODE,<br>Execute Old<br>OP CODE |

### E.4 ZERO PAGE ADDRESSING

Example 5.6: Illustration of zero page addressing

| Clock<br>Cycle | Address Bus | Program Counter | <u>Data Bus</u> | Comments                                          |
|----------------|-------------|-----------------|-----------------|---------------------------------------------------|
| 1              | PC          | PC + 1          | OP CODE         | Fetch OP CODE                                     |
| 2              | PC + 1      | PC + 2          | ADL             | Fetch ADL, De-<br>code OP CODE                    |
| 3              | 00, ADL     | PC + 2          | Data            | Fetch Data                                        |
| 4              | PC + 2      | PC + 3          | New<br>OP CODE  | Fetch New<br>OP CODE, Exe-<br>cute Old<br>OP CODE |

E.5 RELATIVE ADDRESSING – (Branch Positive, no crossing of page boundaries)

Example 5.8: Illustration of relative addressing-branch positive taken, no crossing of page boundaries

| Cycle | Address Bus | Data Bus        | External Operation    | Internal<br>Operation                                              |
|-------|-------------|-----------------|-----------------------|--------------------------------------------------------------------|
| 1     | 0100        | OP CODE         | Fetch<br>OP CODE      | Finish Previous Operation, Increment Program Counter to 101        |
| 2     | 0101        | +50             | Fetch<br>Offset       | Interpret Instruction,<br>Increment Program<br>Counter to 102      |
| 3     | 0102        | Next<br>OP CODE | Fetch Next<br>OP CODE | Check Flags, Add Relative to PCL, Increment Program Counter to 103 |
| 4     | 0152        | Next<br>OP CODE | Fetch Next<br>OP CODE | Transfer Results to PCL, Increment Program Counter to 153          |

# E.6 ABSOLUTE INDEXED ADDRESSING - (with page crossing)

Step 5 is deleted and the data in step 4 is valid when no page crossing occurs.

Example 6.7: Absolute Indexed; With Page Crossing

| Cycle | Address<br>Bus  | Data<br>Bus      | External Operation                 | Internal Operation                                  |
|-------|-----------------|------------------|------------------------------------|-----------------------------------------------------|
| 1     | 0100            | OP CODE          | Fetch OP CODE                      | Finish Previous<br>Operation Increment<br>PC to 101 |
| 2     | 0101            | BAL              | Fetch BAL                          | Interpret Instruction<br>Increment PC to 102        |
| 3     | 0102            | ван              | Fetch BAH                          | Add BAL + Index Increment PC to 103                 |
| 4     | BAH,BAL<br>+X   | Data<br>(Ignore) | Fetch Data<br>(Data is<br>ignored) | Add BAH + Carry                                     |
| 5     | BAH+1,<br>BAL+X | Data             | Fetch Data                         |                                                     |
| 6     | 0103            | Next OP<br>CODE  | Fetch Next<br>OP CODE              | Finish Operation                                    |

# E.7 ZERO PAGE INDEXED ADDRESSING

Example 6.8: Illustration of Zero Page Indexing

| <u>Cycle</u> | Address<br>Bus | Data<br>Bus             | External<br>Operation              | Internal<br>Operation        |
|--------------|----------------|-------------------------|------------------------------------|------------------------------|
| 1            | 0100           | OP CODE                 | Fetch OP CODE                      | Finish Previous<br>Operation |
| 2            | 0101           | BAL                     | Fetch Base<br>Address Low<br>(BAL) | Interpret Instruct-<br>ion   |
| 3            | 00,BAL         | Data<br>(Dis-<br>carded | Fetch<br>Discarded<br>Data         | Add: BAL + X                 |
| 4            | 00,BAL<br>+X   | Data                    | Fetch Data                         |                              |
| 5            | 0102           | Next OP<br>CODE         | Fetch Next OP                      | Finish Operation             |

## E.8 INDEXED INDIRECT ADDRESSING

Example 6.10: Illustration of Indexed Indirect Addressing

| <u>Cycle</u> | Address<br>Bus  | Data<br>Bus           | External Operation        | Internal<br>Operation        |
|--------------|-----------------|-----------------------|---------------------------|------------------------------|
| 1            | 0100            | OP CODE               | Fetch OP CODE             | Finish Previous<br>Operation |
| 2            | 0101            | BAL                   | Fetch BAL                 | Interpret In-<br>struction   |
| 3            | 00,BAL          | DATA (Dis-<br>carded) | Fetch Discard-<br>ed DATA | Add BAL + X                  |
| 4            | 00,BAL<br>+ X   | ADL                   | Fetch ADL                 | Add 1 to BAL + X             |
| 5            | 00,BAL<br>+ X + | 1                     | Fetch ADH                 | Hold ADL                     |
| 6            | ADH, ADL        | DATA                  | Fetch DATA                |                              |
| 7            | 0102            | Next OP               | Fetch Next Ol'            | Finish Operation             |

E.9 INDIRECT INDEXED ADDRESSING (with page crossing)

Step 6 is deleted and the data in step 5 is valid when no page crossing occurs.

Example 6.12: Indirect Indexed Addressing (With Page Crossing)

|              | Address            | Data                  | External                  | Internal                     |
|--------------|--------------------|-----------------------|---------------------------|------------------------------|
| <u>Cycle</u> | Bus                | Bus                   | Operation                 | Operation                    |
| 1            | 0100               | OP CODE               | Load OP CODE              | Finish Previous<br>Operation |
| 2            | 0101.              | IAL                   | Fetch IAL                 | Interpret In-<br>struction   |
| 3            | 00,IAL             | BAL                   | Fetch BAL                 | Add 1 to IAL                 |
| 4            | 00,IAL<br>+ 1      | ВАН                   | Fetch BAH                 | Add BAL to Y                 |
| 5            | BAH,BAL<br>+ Y     | DATA (Dis-<br>carded) | Fetch DATA<br>(Discarded) | Add 1 to BAH                 |
| 6            | BAH + 1<br>BAL + Y | DATA                  | Fetch Data                |                              |
| 7            | 0102               | Next OP<br>CODE       | Fetch Next OP CODE        | Finish This<br>Operation     |

# APPENDIX H

**REVIEW OF BINARY** 

AND

BINARY CODED DECIMAL

**ARITHMETIC** 

The microprocessor automatically takes this into account and corrects for the fact that

| Decimal     |   | BCD      | <u>Hex</u> |          |
|-------------|---|----------|------------|----------|
| 79          | = | 01111001 | 79 =       | 01111001 |
| + <u>12</u> | = | 00010010 | 12 =       | 00010010 |
| 91          | = | 10010001 | 88 =       | 10001011 |

The only difference between Hex and BCD representation is that the microprocessor automatically adjusts for the fact that BCD does not allow for Hex values A - F during add and subtract operations.

The offset which follows a branch instruction is in signed two's complement form which means that

$$$+50 = +80 = 01010000$$
  
and  $$-50 = -80 = \frac{10110000}{00000000}$   
Proof =  $\frac{000000000}{0000000000}$ 

The sign for this operation is in bit 7 where an O equals positive and a 1 equals negative.

This bit is correct for the two's complement representation but also flags the microprocessor whether to carry or borrow from the address high byte.

The following 4 examples represent the combinations of offsets which might occur (all notations are in hexadecimal):

Example H.4.1: Forward reference, no page crossing

| 0105 |      | ENE  | E    |
|------|------|------|------|
| 0106 |      | +.55 | j    |
| 0107 | Next | СP   | CODE |

To calculate next instruction if the branch is taken

with no carry, giving 015C as the result.

### Example H.4.2: Backward reference, no page crossing

015A BNE 015B -55

015C Next OP CODE

To calculate if branch is taken,

Offset -55 = AB = 10101011+ Address Low for Next OP CODE  $\frac{+5C}{07} = \frac{5C}{07} = \frac{01011100}{00000111}$ 

The carry is expected because of the negative offset and is ignored, thus giving 0107 as the result.

### Example H.4.3: Backward reference if page boundary crossed

0105 BNE 0106 -55 0107 Next OP CODE

To calculate if branch is taken, first calculate a low byte

Offset -55 = AB = 10101011Address Low for Next OP CODE 07 = 07 = 00000111 07 = 07 = 0000011107 = 07 = 00000111

There is no carry from a negative offset; therefore, a carry must be made:

This gives 00 B2 as a result.

#### Example H.4.4: Forward reference across page boundary

00B0 BNE 00B1 +55

00B2 Next OP COLE

To calculate next instruction if branch is taken,

Offset 55 = 0101(101)
Address Low for Next
OP CODE  $\frac{B2}{07} = \frac{1011(010)}{0000(111)}$ 

with carry on positive number.

Address High  $\begin{array}{ccc} +1 & 1 = 00000001 \\ 00 = 00000000 \\ \hline 1 = 000000001 \\ \end{array}$ 

which gives 0107.